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(54) Xitte: BRUSHLESS DC MOTOR <X>N'XROL 




(57) Abstraet 

An electronically commutated brusWess DC motor primarily for Pactional horsepower applications of the type where at any instant one 
motor winding is unpowexod and used to detect back HMF zero-crossings which infoimation is used to initiate winding commutations. The 
duration of the pulse produced in this winding due to dissipation of stcsed energy by free^-wheel diodes in parallel with the commutation 
devices after supply of cunent has been removed from this winding is used to provide a measure of motor current. This allows for 
simplified commutation device current limiting circuits and is available for control puiposes which are a function of motor torque. There 
is also disclosed a method for maximising useful power output by reducing the phase angle between the motor current and the back EMF. 
This is accomplished by intrtxiucing a delay in commutating the motor windings beyond the occurrence of each back EMF zero--crossing, 
with the delay being a function of the time between commutations. 
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BRUSHLESS DC MOTOR CONTROL 

TECHNICAL FIELD 

This iavention relates to electioiucally controlled bmshless DC motors (having 
permanent magnet rotors) and in particular, but not solely, to three winding motors for 
5 firactional horsepower applications such as in home appliances and healthcare 
equipment. 
PRIOR ART 

Methods of controlling electronically commutated bmshless DC motors have 
been disclosed in US Patent 4,495,450 (Tokizaki et al) and for use in home appliances 
10 and in particular laundry washing machines in US Patent 4540921 (Boyd et al)» US 
Patent 4857814 (Duncan et al). Some of the basic electronically controlled motor 
(ECM) concepts described in these patents is summarised below with reference to 
Figures 1 and 2. 

An ideal three phase (or winding) DC motor is shown in Figure 1 with 

15 commutation sAvitches which would normally be power FETs. By turning on upper 
switch 1 for phase A and lower switch 2 for phase a static magnetic field will be 
created in the stator. By turning off lower switch 2 for phase B and tuming on lower 
switch 3 for phase C, this magnetic field will move in a clockwise direction. Tuming 
off upper switch 1 for phase A and tuming on upper switch 4 for phase B will cause 

20 the magnetic field to continue to move in the clockwise direction. By repeating this 
"rotation" of the commutation switches the magnetic field in the stator will rotate at 
the same speed as the switching of the switches. A full pattern of switch states for 
cloclcwise rotation is shown in Figure 2. 

Counter-clockwise rotation of the motor is achieved by reversing the switching 

25 pattern sequence of the commutation switches. 

In the method described for creating a rotating field in the stator^ only two 
phases have current intentionally flowing in them at once. This leaves the third 
winding with no intentional current flowing through it. In the cited patents this 
temporarily unused winding is sensed for any voltage induced by the rotating 

30 permanent magnet rotor to provide an indication of rotor position. The induced voltage 
is due to back electromotive force (BEMF). 
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The sensed BEMF waveform is cyclical and varies between trapezxiidal and a 
near sinusoid. The **zero crossings'* of this waveform are due to the edge of the 
permanent magnet poles and provide a consistent point on the rotor to track its 
rotational position. 

5 When such a DC brushless motor is running, each commutation needs to be 

synchronous with the position of the rotor. As soon as the BEMF signal described 
above passes tiirough zero, a decision is made to commutate to the next switching 
pattern to ensure continued rotation is accomplished. Switching must only occur when 
the rotor is in an appropriate angular position. This results in a closed loop feedback 

1 0 system for controlling speed. 

Acceleration or de-acceleration of the rotor is accomplished by either increasing 
or decreasing the strength of the rotating magnetic field in the stater (by pulse width 
modulation (PWM) techniques) since the force on the rotor is proportional to the 
strength of the magnetic field. The commutation frequency will keep pace with the 

1 5 rotor due to the closed loop feedback from the BEMF sensor. 

Maintaining a pre-determined speed under constant load involves controlling 
the strength of the magnetic field in the stator to ensure that the desired commutation 
rate is maintained. To maintain a pre-determined speed of rotation under varying loads 
requires corresponding alteration of the strength of the magnetic field in the stator to 

20 compensate for changes in the load on the rotor. 

The ECM technology disclosed in US Patents 4,540,921 and 4,857,814 requires 
the use of dedicated current limiting circuitry to limit the current which can flow 
through the switching FETs to safe values. Such protection circuitry increases the 
expense of the ECM system and precludes its use in lower power, less expensive 

25 applications. Furthermore, as motor current varies in direct proportion to motor load, it 
would be desimble to use a measure of motor ciurent to control appliance behaviour in 
response to events which cause load changes. With the cited prior art technology such 
load sensing would require furdier expensive hardware. 

The use of BEMF sensing to determine rotor position has many advantages but 

30 has a problem that the output requires filtering using expensive components to 

eliminate transients which occur on coimnutation of the stator windings. In addition, 
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BCM systems of ibis type generally do not run at optimum motor efficiency due to the 
motor current leading the BEMF. 

It is therefore an object of the present invention and/or one or more of flae 
preferred embodiments of the invention to provide an electronically controlled motor 
system which goes some way towards overcoming the above disadvantages. 
DISCLOSURE OF INVENTION 

Accordingly the present invention consists in an electronically commutated 
brashless DC motor wherein at any instant one motor winding is unpowered and used 
to detect back BMP zero-crossings which information is used to initiate winding 
commutations, wherein pulse width modulation of the signals controlling llie 
commutation devices is used to control motor acceleration and uni-directional current 
devices are connected in parallel wifli the conmxutation devices characterised in that 
the duration of the current pulse produced in this winding due to dissipation of stored 
energy by said uni-directional current devices after supply of current has been removed 
from this winding is used to provide a measure of motor current. 

In a second aspect the invention consists in an electronically commutated 
bmshless DC motor wherein at any instant one motor winding is unpowered and used 
to detect back EMF zero-crossings which information is used to initiate winding 
commutations, wherein pulse width modulation of the signals controlling the 
commutation devices is used to control motor acceleration and uni-directional current 
devices are connected in parallel with the commutation devices characterised in that 
the duration of the current pulse produced in this winding due to dissipation of stored 
energy by said uni-directional current devices after supply of current has been removed 
from this winding is measured, the instance of commutation of current in the motor 
windings is delayed beyond the occxnrence of each back EMF zero-crossing to reduce 
the phase angle between the motor current and the back EMF to thereby maximise 
motor efficiency, said delay being calculated as a function of the time between the 
previous commutations and said current pulse duration. 

In a further aspect the invention consists in an electronically commutated motor 
system comprising: 

a bmshless DC motor having a rotor and a stator with at least one phase 
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winding, 

a commutation circuit including a direct current power supply, switching 
devices connected to said power supply to supply current to said at least one winding 
or to selected pairs of stator windings and imidirectional current devices which supply 

5 a current path to dissipate energy stored in each winding after supply of current 
throu^ a switching device has terminated, 

a digitiser circuit which senses the voltage on said at least one winding and 
compares said voltage to A reference signal voltage to thereby detect zero-crossings of 
the back EMF induced in said at least one winding by rotation of the rotor, 

10 a programmed digital processor including memory and input-oulput ports, a 

first port being connected to the output of said digitiser circuit and a second group of 
ports being connected to said commutation circuit to supply switching control signals 
thereto, 

software stored in said memory to caxise said processor to generate said 
15 switching control signals, said software including: 

(a) a table which stores (i) a sequence of combinations of states for each 
switching device in said commutation circuit which if applied sequentially and 
cyclically to said switching devices will cause the stator winding to produce a rotating 
magnetic field, (ii) a sequence of the possible output states of said digitiser circmt for 

20 predetermined angular positions of said rotor which each correspond to one said 

combination of switching device states which will produce torque in the rotor to ensure 
continuing rotation when the rotor is in the corresponding predetermined position, 

(b) a routine for selecting from said table each stored state combination and 
producing digital switching control signals for each switching device having logic 

25 levels corresponding to the states of the particular combination selected at any given 
time, 

(c) a routine for pulse width modulating said switching control signals to 
thereby control the RMS current in the stator windings, 

(d) a routine for setting the duty cycle of the pulse width modulation in 
30 accordance with a stored duty cycle value, 

(e) a i>osition determining routine which reads the output of said digitiser 
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and determines therefrom the angular position of the rotor, 

(f) a routine for calling said selecting routine to select the stored state 
combination corresponding to each sensed rotor position for continuing rotation 
thereof, 

5 (g) a speed determining routine which reads the ouQjut of said digitiser and 

determines therefrom the angular speed of said rotor, 

(h) a table for storing values of desired rotOT speeds, 

(i) a routine for comparing the determined rotor speed with the value of the 
desired rotor speed to produce a speed error value, 

10 (j) a routine for receiving said speed error value and updating said stored 

duty cycle value so as to increase it when rotor speed is less than desired speed and 
decrease it when rotor speed is higher than desired speed, 

(k) a pulse duration determining routine which reads the output of said 
digitiser and determines therefrom the duration of the pulse produced in each phase 

15 winding during dissipation of stored energy after supply of cunrent to each winding 
fhrou^ a switching device has been terminated, 

0) a routine for comparing the so determined pulse duration with a stored 
predetermined maximum value of pulse duration to produce a value for setting said 
stored duty cycle value to a reduced value if the so determined duration is greater than 

20 said maximum value, and 

(m) a routine which reads said decrementing value and updates the currently 

stored duty cycle value. 

BRIEF DESCRIPTION OF DRAWINGS 

Figure 1 is a circuit diagram of an electronically commutated 3 winding 

25 brushless DC motor. 

Figure 2 shows the sequence of states for the commutation switches to cause 

clockwise rotation of the motor of Figure 1, 

Figure 3 is a block circuit diagram of a bnishless DC motor and controUer 
according to the present invention, 
30 Figure 4 is a waveform diagram showing the voltage across a phase of the 

motor of Figure 3, 
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Figure 5 is a part-circuit diagram showing motor current paths through the 
windings. 

Figure 6 is a graph of motor performance at different motor currents, and 
Figure 7 is a waveform diagram showing motor winding current and back EMF. 
5 Figure 8 is a circuit diagram for the back EMF digitiser shown in Figure 3 . 

BEST MODES FOR CARRYING OtJT THE INVENTION 

Figure 3 shows the motor control system of the present invention in block 
diagram form. The main hardware blocks are a permanent magnet three winding motor 
21, motor winding commirtation circuit 22, switched mode DC power supply 23, back 
10 EMF digitiser 24 and micfocomputer 25. The blocks within microcomputer 25 
represent functions executed by software routines which will be described below. 

The present ECM system is described in relation to a motor having a stator with 
three windings (or phases) A. B and C and six saliait poles. Oflier stator configurations 
could be used. The motor has a four pole permanent magnet rotor, aJtJiough a different 
15 number of poles could be adopted. The windings A, B and C are connected together in 
star configuration in this embodiment as indicated in Figure 3. 

Commutation circuit 22 includes pairs of switching devices in the form of 
power field effect transistors (FETs) which are connected across the direct current 
power supply 23 to oommutate each of windings A, B and C in the manner already 
20 described with reference to Figures 1 and 2. Each of the six switching devices making 
up the upper and lower switches for each motor phase is switched by gate signals a+, 
a-, b+, b-, c+, c- produced by microcomputer 25. Switched mode power supply 23 
supplies the DC voltage which is applied across each switching device pair. 

BEMF digitiser 24 receives input signals from the switched end of each of the 
25 motor phases A, B and C for the purposes of monitoring the back EMF induced by the 
rotor. The output ft^om the motor winding which at any given time is not being 
supplied with current fixjm commutation circuit 22 is used for this purpose. The back 
EMF sensing used is as already described with reference to Figures 1 and 2. BEMF 
digitiser 24 supplies at its output a composite digital signal representative of the 
30 analogue signals at its three inputs and derives these logic levels by known comparator 
techniques. The output signal wiU include logic transitions which correspond to the 
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"zero crossings" of the individual analogue BEMF voltages as a rotor pole passes a 
winding pole associated with that phase. This output also contains other information as 

will be described below. 

A suitable circuit for the BEMF digitiser 24 is shown in Figure 8. A comparator 
5 51 is provided with a reference voltage on input 56 and back EMF voltages ftom 
the three motor windings A, B and C on input 55. When the level of the composite 
v^rinding voltage signal at input 55 exceeds V„, (to establish a zero-crossing point) the 
output 57 of the comparator changes state and thereby digitises sufficiently large 
excursions of the winding voltage signal. 
10 Resistors 52 to 54 combine Ihe winding volts^es and the output of tiie 

comparator is therefore determined by the voltage across aU three vraidings. The two 
state output 57 of Ihe conq>arator is fed to microprocessor port 27. As aiicady 
mentioned it is the voltage across the winding which is not being commutated which is 
useful for rotor position and other control puiposes, but since commutation is 
15 determined by the microprocessor it is known at any given time which winding is not 
carrying motor current and thus a time window is established which determines which 
winding voltage is reflected in the digitiser output in any given interval of time. 

In Ihe startup routine the magnitude of the back EMF in the unused winding is 
insufficient to change &e state of the comparator 5 1 and closed loop feedback control 
20 of commutation cannot be used. The value of (which may not be constant) and the 
value of resistor 58 are chosen to set the hysteresis of the digitiser such that zero- 
crossing state transitions will appear at the output 57 at the desired rotor speed for 
switching to closed loop control. This could typically be 330 ipm for some 
applications. 

25 Motor control in the present invention is performed by a single programmed 

microprocessor 25 which supplies the switching signals for commutation circuit 22 
directly without the need for additional logic or "current steering" cwcuitry. The 
required pulse width modulation of the current in the motor windings is also performed 

by micro-processor 25. 
30 Microprocessor 25 is typically an 8-bit single chip CPU and a suitable type is 

Texas Instruments TMS370. The microprocessor hardware components such as CPU, 
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bus, clock, RAM and ROM are not shown in Figure 3, since these essential 
components of microcomputers are well known. Rather, to assist explanation the 
blocks shown within microcomputer 25 each represent a control function to be 
performed by a software routine executed by microprocessor 25 or alternatively 
5 represent a data table or data storage location in memory. 

Commutation switching patterns as shown in Figure 2 are stored in a table 28 
along with a second sequence of switching patterns for producing anti-clockwise 
rotation of the motor. Control pulses for the commutation switches are sjmthesised by 
the commutation control pulse generator routine 29 which includes a pointer value 
10 which points to the location of the switching state pattern in table 28 which is required 
to produce the next commutation for the particular direction of rotation required of 
motor 21. Six commutation drive signals are required to be synthesised although only 
two of these change state on each commutation. 

A startup routine 30 in an initial phase essentially "clocks" pointer 29 through a 
15 switching pattcm sequence with a constant low frequency (or a low but slowly 
increasing frequency). This commutates the stator phases to produce a rotating 
magnetic field at a speed high enough to overcome the hysteresis of the digitiser 24. 
The permanent magnet rotor follows the rotating stator field. 

When the motor is rotating at a speed sufficient to produce a digital back EMF 
20 signal at input port 27 from each unused phase windiag, the motor starting routine 
branches from the open loop control mode described to a closed loop control mode. 
This involves causing a position sensing routine 31 to read the composite digital 
BEMF signal at input port 27 and by using information on which phases are 
instantaneously being conunutated determine the transitions due to the back EMF in 
25 the unused phase and to produce a parallel pattern or digital word following each "zero 
crossing" in each phase and to pass this pattern to routine 29. By accessing a look-up 
table within table 28 this routine locates the commutation switching pattern in table 28 
which is appropriate to be applied to ensure efficient continued rotation of the motor 
having regard to the rotor position as indicated by the pattern supplied by routine 3 1 - 
30 Thus the position of the rotor determines commutation of the stator phases. 

The synthesised commutation control pulses are pulse width modulated when 
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being supplied to the commutatioTi circuit 22. That is, a routine 32 imposes a duty 
cycle on die pulses which are synthesised by routine 29 appropriate to the 
commutation devices through which motor current is to flow in accordance with the 
present value of duty cycle held in location 33. The duty cycle is varied to accelerate 
5 and decelerate motor 21 and to accommodate varying loads on the rotor since rotor 
torque is proportional to motor current and this is determined by the duty cycle of the 
pulse width modulation (TWM). 

A speed sensnig routine 34 reads the BEMF zero crossing patterns and in 
association with a timer routine 36 determines a value representative of the angular 
10 speed of the rotor. Routine 37 compares this value with a predetermined value of 
speed, n, stored in table 38. If the calculated rotor speed is less than n the duty cycle 
value held in location 33 will be incremented (say by 1%) and if the calculated rotor 
speed is greater than n the duty cycle value at 33 will be decremented (by say 1%). The 
predetermined speed value selected from table 38 will depend on the motor appHcaticn 
15 at any particular time. In an example discussed below a typical predetermmed 
op^ational speed is 30OO rpm. 

To protect the commutation circuit switching devices, a current limiting 
fimction must be imposed. As will be described in further detail below with reference 
to Figure 6, the applicants have discovered that the RMS motor current (that is, a 
20 current in any pair of connected phases at any given time) is directly proportional to 
the time duration of the freewheeling current which flows in each windmg after supply 
from a commutation switch has been terminated. This current is of course due to tiie 
well known property of inductors to store energy and the need to dissipate that energy 
on removal of the applied voltage. As is well known in the art, "freewheel" diodes are 
25 connected in parallel with the commutation svntching devices to facilitate such current 
flow. 

Based on this discovery, the current pulse which occurs in each unused winding 
is extracted from the output of BEMF digitiser 24 by routine 40 which in conjunction 
with tuner 36 determines the time duration of each freewheel current pulse. A first 
30 decision routine 41 ascertains whether the pulse width CP is greater than a 

predetermmed value T, stored in location 42, which corresponds to a value of motor 
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current which is at the critical maximum limit for the coimrmtation devices.. If so a 
value 43 is set in location 33 which establishes a PWM duty cycle having atninimal 
ON time. In the example discussed below this might typically be 17%. If the pulse 
width is less than T„ a second decision routine 50 ascertains whether the current pulse 
5 width exceeds the duration of a fiirther lower predetermined value stored at location 
49 and corresponding to normal maximum safe operating current and, if so, a value 44 
is used to decrement the PWM duty cycle value 33. A typical decrement might be 5%. 
If tiie cuirent pulse duiation is less than then no current limiting is required and 
PWM duty cycle control is passed to speed decision routine 37. 
10 In many appUcations the degree of load on the motor 21 or an increase in load 

may constitute useful information for the control of the process in which the ECM 
system is used. Any change in rotor load wiU he reflected in a change in motor cuirent 
and the current pulse measuring routine 40 can be used to provide such sensing 
information. A load monitoring routine 45 is passed the value of the cuirently 
15 determined current pulse width by routine 41 and by ascertaining sudden changes m 
pulse width or by determining that pulse width has reached a predetermined threshold 
useful outputs can be suppUed to an external controller via output ports 46. For 
exanq>le, where the motor is used in a dishwasher to drive a wash liquid pump water 
level can be ascertained by detecting the sudden increase in motor current when the 
20 pump begins to induct water on the suction side. 

In ECM systems of the type described, maximum mnning efficiency of flie 
motor 21 is not achieved owing to flie phase current leading the BEMF so that cuirent 
and voltage peaks do not coincide. This is remedied in the present invention by 
computing a time used to delay the switching of phases after the detection of the zero- 
25 crossing. Thus a delay algorithm 47 (described m more detail below) mtroduces a 

delay in commutation to cause the voltage and current peaks in the motor windings to 
coincide, to thereby optimise the efficiency of the motor. 

The output signal from BEMF digitiser 24 contain transients coincident with the 
occurrence of commutation. Instead of using hardware filters, in the present invention 
30 these transients are filtered out in software. Routine 48 reads the signals on input ports 
27 but interrupts the read function at each commutation occurrence using timing 
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mformation on commutation from routine 29. 

The operation of specific routines outlined above is described in more detail in 
ihe following sections. 
Motor Starting Routine 

5 Motor starting is conducted in two steps by routine 30. The first step involves 

starting rotation of the magnetic field in the stator. This is achieved by stepping 
through the switching patterns (Figure 2) for either clockwise or counter-clockwise 
rotation. The pemianent magnet rotor will follow the rotating field in liie stator. In this 
step the system is open loop. 

10 The end speed of the rotating magnetic field at the completion of this first step 

is deteraiined by the minimum BEMF required for the digitiser 24 to detect rotation of 
the rotor. BEMF magnitude is directly related to the speed of rotation of the rotor. If 
there is no rotation, then BEMF is zero. Alternatively, the faster the rotation the gieater 
BEMF. However, there is a point where the open loop speed of the rotating field in the 

15 stator will be too fast for the rotor to "catch up". This will result in the motor never 
properly starting. This upper speed limit is determined by the inertia of the rotor. In 
one application of the preferred embodiment the initial startup speed maxiimum is 
330 tpm. 

At 330 rpm enough BEMF is generated to allow closed loop operation. As 
20 outlined in the discussion of the prior art, the software will now only change to the 
next stored switch pattern in response to the BEMF. Figure 4 shows how the voltage 
across phase B varies during each switch pattern. The position of the rotor is 
determined when the BEMF waveform crosses a reference voltage V„f for the digitiser 
24. The software then decides the optimum time to change to the next switch pattern. 
25 When the speed of the rotor is under feedback control a commutation will not occur 
until a BEMF "reference crossing^' has occurred. 

The second step in the start up routine involves increasing the speed of ttie rotor 
up to the desired speed of operation by increasing the PWM duty cycle as outlined in 
the description of the prior art. 
30 Speed Control 

Under closed loop control commutations will *'follow" the rotor. In one 
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application of the preferred embodiment 3000 rpm is the desired speed of rotation. 
This equates to 0.02 seconds per revolution of the rotor. In one embodiment the motor 
system is intended to control a motor having a four pole rotor and a six pole stator. 
With such a motor two "electricar' revolutions or complete BEMF cycles are required 
5 to rotate the rotor one meohanioai revolution. Each electrical revolution requires six 
commutations. This means the time between concmiutalions is 1.667 msec* To increase 
the speed of rotation from the initial starting speed of 330 rpm to 3000 tpm, the current 
in flie stator must he increased imtil the commutation rate equals 1 .667 msec. 

Once the rotor is at operational speed, any variation in load on the rotor will 
10 affect its speed. These changes in speed are compensated for by varying the PWM duty 
cycle in the maimer already described to ensure that the desired speed of rotation is 
always maintained. 

The software will alter the value of the PWM duty cycle in two different step 
sizes. For example: 

15 1 . If the speed of the motor is within 10% of the desired speed, then the PWM rate is 
altered by 1%. 

2. If the speed of the motor is not within 10%, the PWM rate is altered by 5%. 

The speeds referred to exemplify one application of the invention. Much higher speeds 

may be selected for other applications. 

20 Freewheel Current Pulse 

Routines 40, 41 , 50 for limiting switehing device current make use of the 
freewheel current pulse. This is explained with reference to Figure 5 (which is a 
simplified version of Figure 1) and Figure 4. Figure 5 shows current flowing in phases 
A and C. This corresponds to phase A upper switch (A+) and phase C lower switch 3 

25 (C-) being on. This current is represented by the solid arrow. 

The dotted arrow represents the current flowing due to the switching pattern of 
the previous commutation. The previous commutation had switch 1 (A+) and 2 (B-) on 
(see Figure 2). When power switch 2 (B-) was turned off and switch 3 (C-) turned on, 
the cuirent in the inductor of phase B could not instantaneously reduce to zero. The 

30 inductor keeps the current flowing. This raises the voltage at the end of phase B until 
freewheel diode 5 in parallel with the upper switch 4 starts to conduct. At this point the 
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"end of phase" voltage is clamped to V+0.6 volts and the current flows out of the 
phase B inductor. This "freewheeling'* current occurs every time a switch is turned off. 
When the current has reduced to zero, the diode stops conducting and the voltage 
across phase B is solely due to the BEMF. The freewheel current pulses for phase B 
5 are designated "CP" in Figure 4. 

When current is flowing in a phase the BEMF cannot he sensed. The 
freewheeling current causes a discontinuity in the sensing of the BEMF. This is 
referred to here as the "current pulse**. The phase B voltage waveform is shown in 
Figure 4 and the current pulses can clearly be seen. 

10 Current Control 

The current through the commutation switches must be limited to safe levels 
appropriate to the switching devices used. In the preferred embodiment the limits for 
the FETs used as the switching devices are 2 amps steady state and 4 amps 
continuously pulsed. Maximum current in each winding is determined by the 

15 difference between the rail voltage and the BEMF generated in the winding divided by 
the resistance of the winding. 



The rate of rise of current is determined by the inductance in the winding. 

dt L 



To ensure that the peak current through the commutation devices at start-np is 
always below 4 amps, the PWM duty cycle is kept to a minimum value. This minimum 
20 value also sets the maximum torque allowed at start-up. The inertia of flie rotor and 
connected lead must be low enough to ensure that the maximum torque allowed at 
start-up can start the motor. 

The initial PWM value is selected to ensure that there is enough starting torque 
to overcome the inertia of the rotor and any initial load. This value is altered on a 
25 commutation by commutation basis according to foin criteria. 
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1. Limit PWM to a pre-defined "safe" value if motor current becomes critical. 

2. Decrease PWM if motor current approaches the critical limit. 

3. Increase PWM if motor imder speed. 

4. Decrease PWM if motor over speed. 

5 Figure 6 shows gr^hs indicative of motor perfonnance in the system already 

described. The hyperbolic curves are torque versus rotor speed graphs for different 
PWM duly cycles (e.g. 9%, 18%, 27%, etc). The more or less horizontal curves are 
plots of switching device RMS current at given PWM duty cycle percentage and rotor 

speed. These graphs show: 

1 . A linear relationship between the PWM duty cycle and motor output torque - 



10 



Toique = ^"^^ and Output Power = F^emf 'matar 

Speed 

therefore Torque = ^— j 



15 



20 



25 



At aconstant speed (say 314 rad/sec or 3000 rpm) V,,^, will stay constant. 
Variation in (via different PWM duty cycles) will cause the torque of the motor to 
vary in a reasonably linear relationship. This means that for a given speed, the 
relationship between PWM duty cycle and load variation is linear. 

2. Minimum PWM duty cycle to ensure that motor current does not exceed 
4 Amps. All of the PWM duty cycle curves of 30% or less never cross the 4 Amp 
horizontal line. This means that irrespective of lotor speed, the motor current will not 
exceed 4 Amps for these duty cycles. This determines a maximum PWM value at stari:- 
up and under motor fault conditions. 

3. Normal operation will not cause the motor current to exceed 2 Amps RMS. 
At a speed of 3 14 rad/sec (3000 rpm) and a PWM duty cycle of 100%, the graphs 
show that the current in the motor does not exceed 2 Amps RMS. 

Figure 6 also shows a graph of RMS motor cunent (right hand Y axis - 
measured in Amps) versus the duration of the current pulse (measured in msecs). This 
graph shows that the duration of flie current pulse is directly proportional to the RMS 
current in the motor. This allows RMS current in the motor to be determined by 
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measuring the duration of the current pulse. This in turn allows the eliminatioii of 
dedicated hardware current limit circuitry which typifies prior art ECMs. 
Current Umit 

Current limit is achieved by limiting the PWM duty cycle value 33 to 17% 
under any fault or starting conditions. A feult condition is established when routine 50 
ascertains fix>m the datapassed ftom routine 40 that the cutimt pulse duration is longer 
than 1 msec. This coiresponds to appiox 3 Amps RMS flowing through the FETs. If 
this condition is dotted, the duty cycle value is immediately Kmited lo 17% and the 
software will try to restore the motor to fcU speed. If a predetermined number of 
attempts fail to restore the motor to full speed the software will flag an error to the 



user. 



15 



Current Trip 

Current trip is facilitated by the switch mode power supply (SMPS) 23. If the 
current in the primary inductor rises above 2.25 - 3.15 Amps then the top switch turns 
off until the next cycle of the SMPS is initiated. This limits the amount of energy that 
can be transferred to the secondary. 

The typical feult that will cause this condition to occur is an upper and a lower 
FET being on at the same time due to loss of software control or a hardware feult. The 
amount of current that will flow through the FETs is reUant on how much energy is in 
the secondary inductor of the transformer and the smoothing capacitor across the 40 V 
rail. The peak energy ihat the N channel FETs in particular can handle before being 
damaged is 30 mJoules. 
Optimising Motor Efficiency 

The function of algorithm 47 is to keep the BEMF and current waveforms in 
25 phase to optimise motor efficiency, as is appreciated from ttie equation for motor 
power: 

Pfnu^r = X / ^ X co&(phase tingle} 

fOWer r ]jEMF * motor ^ 



20 



To keep the phase angle as small as possible mvolves delaying every 
commutation an amount of time that is specific to the previous commutatior 
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The equation for calciilating fliis dynamic commutation delay is: 

(Desii6d Commutation rate - Curraiit Pulse Duration) 
Optimum Delay = ^ ^~ 

This equation can be derived graphically. Figure 7 shows two traces. The 
sinusoidal trace is the BEMF induced in tiic winding of the stator as the permanent 
magnet spins around. The trapezoidal trace I,,.^ is the current flowing tiurough a given 
5 winding, -nie aim is to make t, = t,. This ensures tiiat the current waveforai is centied 
with respect to ttie BEMF waveform, to minimise the phase angle. 

time between commutations (TBC) = t, + tg + 1, 

therefore t^ == TBC - t, - 1, 

10 rearrange and appreciating that t,= t, = t^ 

+ = TBC - fj 
It^ = TBC - ts 



where = Optimum Delay 

tj = Current Pulse Duration 

TBC = Current Commutation Rate. 

15 This algorithm is dynamically executed with each commutation. However in 

applications of substantially constant speed operation delay time values may be pre- 
calculated and pre-loaded in microprocessor 25 to be applied during each motor 
operating mode. The calculation in this case uses a value of time between 
commutations based on desired commutation rate and a value of current pulse duration 

20 determined by computes: modelling or assumption. 

The present motor system is able to be implemented with relatively low PWM 
rates and can achieve low noise operation. Using large inductance motors (salient pole 
for example) facilitate the use of low PWM rates. 
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CLAIMS: 

1 . An electronically commutated brushless DC motor wherein at any instant one 
motor winding is impowered and used to detect back EMF zero-crossings which 
information is used to initiate winding conmiutations, wherein pulse width modulation 

5 of the signals controUiag flie commutation devices is used to control motor 

acceleration and uni-directional current devices are connected in parallel with the 
commutation devices characterised in that the duration of the current pulse produced 
in this winding due to dissipation of stored energy by said uni-directional current 
devices after supply of current has been removed from this winding is used to provide 

10 a measure of motor current 

2. An electronically commutated brushless DC motor as claimed in claim 1 
wherein said measure of motor current controls said pulse width modulation duty cycle 
to limit the motor current to safe values- 

3 . An electronically commutated brushless DC motor wherein at any instant one 
15 motor winding is unpowered and used to detect back EMF zero-crossings which 

information is used to initiate winding commutations, wherein pulse width modulation 
of the signals controlling the commutation devices is used to control motor 
acceleration and uni-directional current devices are connected in parallel with the 
commutation devices characterised in that the duration of the current pulse produced 

20 in this winding due to dissipation of stored energy by said uni-directional current 
devices after supply of current has been removed from this winding is measured, the 
instance of commutation of current in the motor windings is delayed beyond the 
occurrence of each back EMF zero-crossing to reduce the phase angle between the 
motor current and the back EMF to thereby maTumise motor efficiency, said delay 

25 being calculated as a function of the time between the previous commutations and said 
current pulse duration, 

4- An electronically commutated bmshless DC motor as claimed in claim 3 
wherein said function is half the difference of the time between winding commutations 
and said current pulse duration. 
30 5. An electronically commutated motor system comprising: 

a bmshless DC motor having a rotor and a stator with at least one phase 
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winding, 

a commutation circuit including a direct current power supply, switching 
devices connected to said power supply to supply current to said at least one v^ding 
or to selected pairs of stator windings and unidirectional current devices which supply 
a current path to dissipate energy stored in each winding afier supply of current 
through a switehing device has tenninated, 

a digitiser circuit which senses the voltage on said at least one winding and 
compares said voltage to A reference signal voltage to thereby detect zero-crossings of 
the back EMF induced in said at least one winding by rotation of the rotor, 

a programmed digital processor including memory and input-oulput ports, a 
first port being connected to the output of said digitiser circuit and a second groiq, of 
ports being connected to said commutation circuit to supply switching control signals 
thereto, 

software stored in said memory to cause said processor to generate said 
1 5 svsdtching control signals, said software including: 

(a) a table which stores (i) a sequence of combinations of states for each 
switehing device in said commutation circuit which if applied sequentially and 
cyclically to said switching devices wiU cause the stator winding to produce a rotating 
magnetic field, (ii) a sequence of the possible output states of said digitiser circuit for 
predetermined angular positions of said rotor which each correspond to one said 
combination of switching device states which will pit^duce torque in the rotor to ensure 
continuing rotation when the rotor is in the corresponding predetermined position, 

(b) a routine for selecting from said table each stored state combination and 
producing digital switching control signals for each switching device having logic 
levels corresponding to the states of the particular combination selected at any given 
time, 

(c) a routine for pulse width modulating said switehing control signals to 
thereby control the RMS current in the stator windings, 

(d) a routine for setting the duty cycle of the pulse width modulation in 
30 accordance with a stored duty cycle value, 

(e) a position determining routine which reads the output of said digitiser 

SUBSTITUE SHEET (Rule 26) 



20 



25 



W0 98/35«8 




PCT/N298MNW12 

-19- 

and dctetmines therefrom the angular position of the rotor. 

(t) -~«ti»-forcalli„gsaidselectingroutineto'selectthestored^te 
combination corresponding to each sensed rotor position for continuing rotation 

5 (g) ^^^d^tennining routine which reads the output of said digitiser and 

detemmies therefrom the angular speed of said rotor, 

(h) a table for storing values of desired rotor speeds, 

a) ^ for comparing the determined rotor speed with the value of tiie 

desired rotor speed to produce a speed error value, 

10 G) -""ti«e for receiving said speed error value and updating said sterol 

duly cycle valne so as to increase it when rotor speed is less flian desired speed and 
decrease it when rotor speed is higher than desired speed, 

(k) a pulse duration detemrining routine which reads the output of said 
dxgmser and detennines therefrom the duration of tiie pulse produced in each phase 

windmg during dissipation of stored energy after supply of current to each Winding 
through a switching device has been tenninated, 

(1) a routine for comparing the so determined pulse duration with a stored 
predetermined maximum value of pulse duration to produce a value for setting said 

^^-^^^^^yclevaluetoareducedvalueifthesodetemaineddurationisgreate^ 
said maximuin value, and 

(m) a routine which reads said decrementing value and updates tire currently 
Stored duty cycle value. 

6. An electronically commut^ted motor system according to claim 5 wherein said 
^tator has at least three phase wmdings, said switching devices sequentially connect 
selected pairs of windings to said power supply and said digitiser is comrected to each 
winding to detect zero crossings of tiie back EMF induced in all windings. 

7. An electronically commutated motor syst^ according to claim 5 wherein flrere 
.s mcluded a routine to reduce the phase angle between tiie current and the back EMF 
by delaying the switching of phase windings when said digitising circuit detects a zero- 

30 crossing. 

8. An electronically commutated motor system according to claim 7 wherein tire 
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delaying routine implements a delay which is equal to half the difference between the 
time interval between the immediately preceding commutations and the duration of the 
current pulse produced in the immediately preceding commutated phase winding 
during dissipation of stored energy after supply of current to that winding has been 
5 terminated. 

9. An electronically commutated motor system according to claim 5 wherein there 
is included a motor start routine which causes said selecting routine to successively 
select stored state combinations fix>m said table and supply switching control signals to 
each switching device at a constant low frequency or a low progressively increasing 
10 frequency which is unaffected by data from said position determining routine imtil a 
predetermined speed has been attained, whereupon data from said position determining 
routine is then used to call said selecting routine to determine the switching device 
control signals. 

10- An electronically commutated motor system according to claim 5 wherein there 
15 is included a routine which compares said speed error value with a stored threshold 
value and if the error value exceeds the threshold value the stored duty cycle value is 
incremented or decremented by a larger value than is the case when the error value 
does not exceed the threshold value. 

11. An electronically commutated motor system according to claim 5 wherein there 
20 is included a routine which compares said pulse duration with a second stored 

predetermined value less than said predetermined maximum value to decrement said 
stored duty cycle value by a predetermined amount if the pulse duration is greater ttian 
said second predetermined value. 

12. An electronically commutated motor system according to claim 5 wherein there 
25 is included a routine which compares the updating duty cycle value with a stored 

predetermined maximum value and if the updating value exceeds the maximum value 
the duty cycle value is set to said maximum value. 

13. An electronically commutated motor system according to claim 12 wherein a 
second maximum value of duty cycle is stored and used when said start routine is 

30 being executed. 

14- An electronically commutated motor system according to claim 5 wherein there 
SUBSTITUE SHEET (Rule 26) 



W098/3S428 

"^3^ PCT/NZ98/00012 

-21- 

is included a routine which contn>ls Ihe routine which reads the outputs of said 
yusor rn accordance with data passed from said selecting routine to cause ou^uts of 
the d,gxt,ser not to be read at times when th«e are t^sitions in the switching device 
control signals. 
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